6. The method of claim 1 wherein the electronic representation is 
received in the form of a schematic electronically captured. 

7. The method of claim 1 wherein the electronic representation is 
received in the form selected from a group comprising: a netlist, an electronically 
captured schematic, and a coded hardware description language. 

8. The method of claim 1 wherein the connections include at least one of 
conductive lines and switches. 

9. The method of claim 1 wherein the target hardware device is selected 
from a group comprising: a complex programmable logic device (CPLD), a field 
programmable gate array (FPGA), an application specific integrated circuit (ASIC), a 
programmable logic device, a general purpose microprocessor, and a board level 
circuit implementation. 

10. The method of claim 1 further comprising iteratively repeating the 
determining a path criticahty and the partitioning at least a portion of the source 
design. 

1 1 . The method of claim 1 , further comprising: 

determining whether to repartition the at least a portion of the source design 
after the partitioning; and 

if necessary, adjusting the estimates of delays from future partitions. 

12. The method of claim 1 1 wherein determining whether to repartition at 
least a portion of the source electronic design is determined by comparing the critical 
path delays resulting from the partitioning cut with the estimate of critical path delays 
prior to the partitioning cut. 

13. The method of claim 10 wherein adjusting the estimates of delays from 
future partitions comprises: 
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substituting a percentage of delays attributed to the partition in the statistical 
estimate with a new percentage derived from the critical path delay results from the 
partition. 

14. The method of claim 1 wherein the statistical estimate for future delay 
comprises: 

receiving at least one source design; 

placing the at least one source design using partitioning methods to place the 
device across boundaries in the target device; and 

generating statistical data corresponding to each type of boimdary crossed in 
the target device. 

wherein the statistical data represents the proportion of each hierarchical type 
of cut of the entire number of cuts in the fully placed design 

15. The method of claim 14 wherein the statistical data represents the 
proportion of each hierarchical type of cut of the entire number of cuts in the fully 
placed design. 

16. The method of claim 1 5 wherein the statistical estimates correspond to 
the weighted average of the statistical data generated. 

17. The method of claim 16 wherein the weighted average is based on a 
predetermined number or percentage of the slowest delays. 

18. The method of claim 1 6 wherein the weighted average is based on a 
predetermined number or percentage of the fastest delays. 

19. A method for generating statistical estimates for future delays on uncut 
connections on a path in placing a design by partitioning methods comprising: 

receiving at least one source design; 

placing the at least one source design using partitioning methods to place the 
device across boundaries in the target device; and 

generating statistical data corresponding to each type of boimdary crossed in 
the target device. 
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20. The method of claim 19 wherein the statistical data represents the 
proportion of each hierarchical type of cut of the entire number of cuts in the fully 
placed design. 

2 1 . The method of claim 1 9 wherein the statistical estimates correspond to 
the weighted average of the statistical data generated. 

22. The method of claim 21 wherein the weighted average is based on a 
predetermined number or percentage of the slowest delays. 

23. The method of claim 21 wherein the weighted average is based on a 
predetermined number or percentage of the fastest delays. 

24. A computer program product comprising: 

a machine readable memory on which is provided program instructions for a 
method of placing a source electronic design into a target hardware device by 
partitioning methods, the instructions comprising: 

code for receiving an electronic representation of the source electronic 

design; 

code for determining a path criticality in the source electronic design 
based on determining an actual delay corresponding to a connection already placed 
across a first boundary in the target device, 

code for determining a statistical estimate for a future delay 
corresponding to an associated fiiture connection to be placed across a second 
boundary in the target device; and 

code for partitioning at least a portion of the source design by placing 
the at least a portion of the source design across boundaries in the target device based 
on the criticalities determined. 

25. The computer program product of claim 24 wherein the code for 
determining the statistical estimate for future delay comprises: 

code for receiving at least one source design; 



ALTRP061 



32 



PATENT 



code for placing the at least one source design using partitioning methods to 
place the device across boundaries in the target device; and 

code for generating statistical data corresponding to each type of boundary 
crossed in the target device, 

wherein the statistical data represents the proportion of each hierarchical type 
of cut of the entire number of cuts in the fully placed design 

26. The computer program product of claim 25 wherein the statistical data 
represents the proportion of each hierarchical type of cut of the entire number of cuts 
in the fiiUy placed design. 

27. The computer program product of claim 26 wherein the statistical 
estimates correspond to the weighted average of the statistical data generated. 

28 . The computer program product of claim 27 wherein the weighted 
average is based on a predetermined number or percentage of the slowest delays. 

29. The computer program product of claim 28 wherein the weighted 
average is based on a predetermined number or percentage of the fastest delays. 

30. A computer system having a central processing unit (CPU) coupled to 
a memory, comprising: 

an interface for communicating with an individual; 

wherein the computer system is configured to receive an electronic 
representation of the source electronic design; 

wherein the computer system is further configured to, 

determine a path criticality in the source electronic design based on 
determining an actual delay corresponding to a connection already placed across a 
first boundary in the target device, and 

determine a statistical estimate for a fixture delay corresponding to an 
associated future cormection to be placed across a second boundary in the target 
device; and 
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wherein the computer system is further configured to partition at least 
a portion of the source design by placing the at least a portion of the source design 
across boundaries in the target device based on the determined actual delay. 
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